X-Git-Url: https://git.r.bdr.sh/rbdr/super-polarity/blobdiff_plain/38c7d3f9eb7d63937c6654ff5dd6046ce02dd59c..3de51c6f55d304f038df1b77c8ab346e2a187fe1:/Super%20Polarity/InputController.cs diff --git a/Super Polarity/InputController.cs b/Super Polarity/InputController.cs index 79bd039..c92bb9c 100644 --- a/Super Polarity/InputController.cs +++ b/Super Polarity/InputController.cs @@ -37,11 +37,42 @@ namespace SuperPolarity public static void UpdateInput() { - Poll(); DispatchMoveEvents(); DispatchRegisteredEvents(); } + public static void UpdateInput(bool highPriorityOnly) + { + Poll(); + DispatchPauseEvent(); + if (!highPriorityOnly) + { + UpdateInput(); + } + } + + public static void DispatchPauseEvent() + { + // OK THIS IS ALL KINDS OF WRONG. THIS IS A PLACEHOLDER BECAUSE DEMO! + var keyPressed = false; + if ((InputKeyboardState.IsKeyDown(Keys.Enter) || InputGamePadState.IsButtonDown(Buttons.Start))) { + keyPressed = true; + if(!BlockedButtons.Contains("pause") && !BlockedKeys.Contains("pause")) + { + BlockedButtons.Add("pause"); + BlockedKeys.Add("pause"); + Console.WriteLine("Dispatch"); + Dispatch("pause", 0); + } + } + + if (!keyPressed) + { + BlockedButtons.Remove("pause"); + BlockedKeys.Remove("pause"); + } + } + private static void Poll() { InputGamePadState = GamePad.GetState(Microsoft.Xna.Framework.PlayerIndex.One); @@ -175,6 +206,21 @@ namespace SuperPolarity listenerList.Add(listener); } + public static void Unbind(string eventName, Action listener) + { + List> listenerList; + bool foundListeners; + + if (!Listeners.ContainsKey(eventName)) + { + return; + } + + foundListeners = Listeners.TryGetValue(eventName, out listenerList); + + listenerList.Remove(listener); + } + public static void Dispatch(string eventName, float value) { List> listenerList; @@ -187,9 +233,9 @@ namespace SuperPolarity return; } - foreach (Action method in listenerList) + for (var i = listenerList.Count - 1; i >= 0; i--) { - method(value); + listenerList[i](value); } }